package com.linyaonan.leetcode.easy._509;

/**
 *
 * 斐波那契数，通常用 F(n) 表示，形成的序列称为斐波那契数列。该数列由 0 和 1 开始，后面的每一项数字都是前面两项数字的和。也就是：
 *
 * F(0) = 0,   F(1) = 1
 * F(N) = F(N - 1) + F(N - 2), 其中 N > 1.
 * 给定 N，计算 F(N)。
 *
 *  
 *
 * 示例 1：
 *
 * 输入：2
 * 输出：1
 * 解释：F(2) = F(1) + F(0) = 1 + 0 = 1.
 * 示例 2：
 *
 * 输入：3
 * 输出：2
 * 解释：F(3) = F(2) + F(1) = 1 + 1 = 2.
 * 示例 3：
 *
 * 输入：4
 * 输出：3
 * 解释：F(4) = F(3) + F(2) = 2 + 1 = 3.
 *  
 *
 * 提示：
 *
 * 0 ≤ N ≤ 30
 *
 * @author: Lin
 * @date: 2020/1/1
 */
public class FibonacciNumber {
    public int fib(int N) {
        return fibGet(N);
    }

    public int fib2(int n) {
        if (n == 0) {
            return 0;
        }
        if (n == 1) {
            return 1;
        }

        int last1 = 1;
        int last2 = 1;
        int r = 1;
        int c = 2;
        while (c != n) {
            r = last1 + last2;
            last1 = last2;
            last2 = r;
            c++;
        }

        return r;
    }

    private int fibGet(int n) {
        if (n == 0 || n == 1) {
            return n;
        } else {
            return fibGet(n - 1) + fibGet(n - 2);
        }
    }
}
